package com.zjdiepu.www.dao.base;

import java.util.List;
import java.util.Set;

import org.apache.ibatis.annotations.Param;

import com.zjdiepu.www.model.base.dto.SysUserRole;
import com.zjdiepu.www.model.base.ext.SysUserRoleExt;

/**
 * 用户角色对应表dao层操作<br/>
 * @author xiongxiaotun<br/>
 * @time 2017年04月05日 15时24分<br/>
 * @since 1.0<br/>
 */
public interface SysUserRoleMapper {
	/**
	 * 主键删除
	 * @param id
	 * @return
	 */
	int deleteByPrimaryKey(String id);

	/**
	 * 添加记录
	 * 
	 * @param sysUserRole
	 * @return
	 */
	int insert(SysUserRole sysUserRole);

	/**
	 * 批量添加记录
	 * @param sysUserRoles
	 * @return
	 */
	int insertBatch(List<SysUserRole> sysUserRoles);

	/**
	 * 主键查询
	 * @param id
	 * @return
	 */
	SysUserRole selectByPrimaryKey(String id);

	/**
	 * 主键更新：只更新不是null值字段，字符串还要求trim()后长度不为0
	 * @param sysUserRole
	 * @return
	 */
	int updateByPrimaryKeySelective(SysUserRole sysUserRole);

	/**
	 * 主键更新
	 * @param sysUserRole
	 * @return
	 */
	int updateByPrimaryKey(SysUserRole sysUserRole);
	
	/**
	 * 条件查询
	 * @param sysUserRoleExt
	 * @return
	 */
	List<SysUserRole> selectByExt(SysUserRoleExt sysUserRoleExt);
	
	/**
	 * 条件统计
	 * @param sysUserRoleExt
	 * @return
	 */
	int countByExt(SysUserRoleExt sysUserRoleExt);
	
	/**
	 * 根据主键清除空字段，设置值为null
	 * @param fieldNames 字段名
	 * @param id 主键
	 */
	void clearEmpty(@Param("fieldNames")Set<String> fieldNames, @Param("id")String id);
	/**
	 * @author xiongxiaotun <br/>
	 * @Title deleteBy  <br/>
	 * @Description 条件删除 <br/>
	 * @param sysUserRole
	 * @version V1.0  <br/>
	 */
	void delete(SysUserRole sysUserRole);
}